package com.ttj.domain.oracle.gen;

import java.util.ArrayList;
import java.util.List;

public class SysconfSellCategoryCriteria {
    protected String orderByClause;

    protected boolean distinct;

    protected List<Criteria> oredCriteria;

    protected Integer mysqlOffset;

    protected Integer mysqlLength;

    public SysconfSellCategoryCriteria() {
        oredCriteria = new ArrayList<Criteria>();
    }

    public void setOrderByClause(String orderByClause) {
        this.orderByClause = orderByClause;
    }

    public String getOrderByClause() {
        return orderByClause;
    }

    public void setDistinct(boolean distinct) {
        this.distinct = distinct;
    }

    public boolean isDistinct() {
        return distinct;
    }

    public List<Criteria> getOredCriteria() {
        return oredCriteria;
    }

    public void or(Criteria criteria) {
        oredCriteria.add(criteria);
    }

    public Criteria or() {
        Criteria criteria = createCriteriaInternal();
        oredCriteria.add(criteria);
        return criteria;
    }

    public Criteria createCriteria() {
        Criteria criteria = createCriteriaInternal();
        if (oredCriteria.size() == 0) {
            oredCriteria.add(criteria);
        }
        return criteria;
    }

    protected Criteria createCriteriaInternal() {
        Criteria criteria = new Criteria();
        return criteria;
    }

    public void clear() {
        oredCriteria.clear();
        orderByClause = null;
        distinct = false;
    }

    /**
     * @param mysqlOffset 
	 *            指定返回记录行的偏移量<br>
	 *            mysqlOffset= 5,mysqlLength=10;  // 检索记录行 6-15
     */
    public void setMysqlOffset(Integer mysqlOffset) {
        this.mysqlOffset=mysqlOffset;
    }

    /**
     * @param mysqlLength 
	 *            指定返回记录行的最大数目<br>
	 *            mysqlOffset= 5,mysqlLength=10;  // 检索记录行 6-15
     */
    public Integer getMysqlOffset() {
        return mysqlOffset;
    }

    /**
     * @param mysqlOffset 
	 *            指定返回记录行的偏移量<br>
	 *            mysqlOffset= 5,mysqlLength=10;  // 检索记录行 6-15
     */
    public void setMysqlLength(Integer mysqlLength) {
        this.mysqlLength=mysqlLength;
    }

    /**
     * @param mysqlLength 
	 *            指定返回记录行的最大数目<br>
	 *            mysqlOffset= 5,mysqlLength=10;  // 检索记录行 6-15
     */
    public Integer getMysqlLength() {
        return mysqlLength;
    }

    protected abstract static class GeneratedCriteria {
        protected List<Criterion> criteria;

        protected GeneratedCriteria() {
            super();
            criteria = new ArrayList<Criterion>();
        }

        public boolean isValid() {
            return criteria.size() > 0;
        }

        public List<Criterion> getAllCriteria() {
            return criteria;
        }

        public List<Criterion> getCriteria() {
            return criteria;
        }

        protected void addCriterion(String condition) {
            if (condition == null) {
                throw new RuntimeException("Value for condition cannot be null");
            }
            criteria.add(new Criterion(condition));
        }

        protected void addCriterion(String condition, Object value, String property) {
            if (value == null) {
                throw new RuntimeException("Value for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value));
        }

        protected void addCriterion(String condition, Object value1, Object value2, String property) {
            if (value1 == null || value2 == null) {
                throw new RuntimeException("Between values for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value1, value2));
        }

        public Criteria andIdIsNull() {
            addCriterion("ID is null");
            return (Criteria) this;
        }

        public Criteria andIdIsNotNull() {
            addCriterion("ID is not null");
            return (Criteria) this;
        }

        public Criteria andIdEqualTo(Integer value) {
            addCriterion("ID =", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotEqualTo(Integer value) {
            addCriterion("ID <>", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdGreaterThan(Integer value) {
            addCriterion("ID >", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdGreaterThanOrEqualTo(Integer value) {
            addCriterion("ID >=", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdLessThan(Integer value) {
            addCriterion("ID <", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdLessThanOrEqualTo(Integer value) {
            addCriterion("ID <=", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdIn(List<Integer> values) {
            addCriterion("ID in", values, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotIn(List<Integer> values) {
            addCriterion("ID not in", values, "id");
            return (Criteria) this;
        }

        public Criteria andIdBetween(Integer value1, Integer value2) {
            addCriterion("ID between", value1, value2, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotBetween(Integer value1, Integer value2) {
            addCriterion("ID not between", value1, value2, "id");
            return (Criteria) this;
        }

        public Criteria andOneCategoryIsNull() {
            addCriterion("ONE_CATEGORY is null");
            return (Criteria) this;
        }

        public Criteria andOneCategoryIsNotNull() {
            addCriterion("ONE_CATEGORY is not null");
            return (Criteria) this;
        }

        public Criteria andOneCategoryEqualTo(String value) {
            addCriterion("ONE_CATEGORY =", value, "oneCategory");
            return (Criteria) this;
        }

        public Criteria andOneCategoryNotEqualTo(String value) {
            addCriterion("ONE_CATEGORY <>", value, "oneCategory");
            return (Criteria) this;
        }

        public Criteria andOneCategoryGreaterThan(String value) {
            addCriterion("ONE_CATEGORY >", value, "oneCategory");
            return (Criteria) this;
        }

        public Criteria andOneCategoryGreaterThanOrEqualTo(String value) {
            addCriterion("ONE_CATEGORY >=", value, "oneCategory");
            return (Criteria) this;
        }

        public Criteria andOneCategoryLessThan(String value) {
            addCriterion("ONE_CATEGORY <", value, "oneCategory");
            return (Criteria) this;
        }

        public Criteria andOneCategoryLessThanOrEqualTo(String value) {
            addCriterion("ONE_CATEGORY <=", value, "oneCategory");
            return (Criteria) this;
        }

        public Criteria andOneCategoryLike(String value) {
            addCriterion("ONE_CATEGORY like", value, "oneCategory");
            return (Criteria) this;
        }

        public Criteria andOneCategoryNotLike(String value) {
            addCriterion("ONE_CATEGORY not like", value, "oneCategory");
            return (Criteria) this;
        }

        public Criteria andOneCategoryIn(List<String> values) {
            addCriterion("ONE_CATEGORY in", values, "oneCategory");
            return (Criteria) this;
        }

        public Criteria andOneCategoryNotIn(List<String> values) {
            addCriterion("ONE_CATEGORY not in", values, "oneCategory");
            return (Criteria) this;
        }

        public Criteria andOneCategoryBetween(String value1, String value2) {
            addCriterion("ONE_CATEGORY between", value1, value2, "oneCategory");
            return (Criteria) this;
        }

        public Criteria andOneCategoryNotBetween(String value1, String value2) {
            addCriterion("ONE_CATEGORY not between", value1, value2, "oneCategory");
            return (Criteria) this;
        }

        public Criteria andTwoCategoryIsNull() {
            addCriterion("TWO_CATEGORY is null");
            return (Criteria) this;
        }

        public Criteria andTwoCategoryIsNotNull() {
            addCriterion("TWO_CATEGORY is not null");
            return (Criteria) this;
        }

        public Criteria andTwoCategoryEqualTo(String value) {
            addCriterion("TWO_CATEGORY =", value, "twoCategory");
            return (Criteria) this;
        }

        public Criteria andTwoCategoryNotEqualTo(String value) {
            addCriterion("TWO_CATEGORY <>", value, "twoCategory");
            return (Criteria) this;
        }

        public Criteria andTwoCategoryGreaterThan(String value) {
            addCriterion("TWO_CATEGORY >", value, "twoCategory");
            return (Criteria) this;
        }

        public Criteria andTwoCategoryGreaterThanOrEqualTo(String value) {
            addCriterion("TWO_CATEGORY >=", value, "twoCategory");
            return (Criteria) this;
        }

        public Criteria andTwoCategoryLessThan(String value) {
            addCriterion("TWO_CATEGORY <", value, "twoCategory");
            return (Criteria) this;
        }

        public Criteria andTwoCategoryLessThanOrEqualTo(String value) {
            addCriterion("TWO_CATEGORY <=", value, "twoCategory");
            return (Criteria) this;
        }

        public Criteria andTwoCategoryLike(String value) {
            addCriterion("TWO_CATEGORY like", value, "twoCategory");
            return (Criteria) this;
        }

        public Criteria andTwoCategoryNotLike(String value) {
            addCriterion("TWO_CATEGORY not like", value, "twoCategory");
            return (Criteria) this;
        }

        public Criteria andTwoCategoryIn(List<String> values) {
            addCriterion("TWO_CATEGORY in", values, "twoCategory");
            return (Criteria) this;
        }

        public Criteria andTwoCategoryNotIn(List<String> values) {
            addCriterion("TWO_CATEGORY not in", values, "twoCategory");
            return (Criteria) this;
        }

        public Criteria andTwoCategoryBetween(String value1, String value2) {
            addCriterion("TWO_CATEGORY between", value1, value2, "twoCategory");
            return (Criteria) this;
        }

        public Criteria andTwoCategoryNotBetween(String value1, String value2) {
            addCriterion("TWO_CATEGORY not between", value1, value2, "twoCategory");
            return (Criteria) this;
        }

        public Criteria andDetailCategoryIsNull() {
            addCriterion("DETAIL_CATEGORY is null");
            return (Criteria) this;
        }

        public Criteria andDetailCategoryIsNotNull() {
            addCriterion("DETAIL_CATEGORY is not null");
            return (Criteria) this;
        }

        public Criteria andDetailCategoryEqualTo(String value) {
            addCriterion("DETAIL_CATEGORY =", value, "detailCategory");
            return (Criteria) this;
        }

        public Criteria andDetailCategoryNotEqualTo(String value) {
            addCriterion("DETAIL_CATEGORY <>", value, "detailCategory");
            return (Criteria) this;
        }

        public Criteria andDetailCategoryGreaterThan(String value) {
            addCriterion("DETAIL_CATEGORY >", value, "detailCategory");
            return (Criteria) this;
        }

        public Criteria andDetailCategoryGreaterThanOrEqualTo(String value) {
            addCriterion("DETAIL_CATEGORY >=", value, "detailCategory");
            return (Criteria) this;
        }

        public Criteria andDetailCategoryLessThan(String value) {
            addCriterion("DETAIL_CATEGORY <", value, "detailCategory");
            return (Criteria) this;
        }

        public Criteria andDetailCategoryLessThanOrEqualTo(String value) {
            addCriterion("DETAIL_CATEGORY <=", value, "detailCategory");
            return (Criteria) this;
        }

        public Criteria andDetailCategoryLike(String value) {
            addCriterion("DETAIL_CATEGORY like", value, "detailCategory");
            return (Criteria) this;
        }

        public Criteria andDetailCategoryNotLike(String value) {
            addCriterion("DETAIL_CATEGORY not like", value, "detailCategory");
            return (Criteria) this;
        }

        public Criteria andDetailCategoryIn(List<String> values) {
            addCriterion("DETAIL_CATEGORY in", values, "detailCategory");
            return (Criteria) this;
        }

        public Criteria andDetailCategoryNotIn(List<String> values) {
            addCriterion("DETAIL_CATEGORY not in", values, "detailCategory");
            return (Criteria) this;
        }

        public Criteria andDetailCategoryBetween(String value1, String value2) {
            addCriterion("DETAIL_CATEGORY between", value1, value2, "detailCategory");
            return (Criteria) this;
        }

        public Criteria andDetailCategoryNotBetween(String value1, String value2) {
            addCriterion("DETAIL_CATEGORY not between", value1, value2, "detailCategory");
            return (Criteria) this;
        }

        public Criteria andPriceIsNull() {
            addCriterion("PRICE is null");
            return (Criteria) this;
        }

        public Criteria andPriceIsNotNull() {
            addCriterion("PRICE is not null");
            return (Criteria) this;
        }

        public Criteria andPriceEqualTo(Double value) {
            addCriterion("PRICE =", value, "price");
            return (Criteria) this;
        }

        public Criteria andPriceNotEqualTo(Double value) {
            addCriterion("PRICE <>", value, "price");
            return (Criteria) this;
        }

        public Criteria andPriceGreaterThan(Double value) {
            addCriterion("PRICE >", value, "price");
            return (Criteria) this;
        }

        public Criteria andPriceGreaterThanOrEqualTo(Double value) {
            addCriterion("PRICE >=", value, "price");
            return (Criteria) this;
        }

        public Criteria andPriceLessThan(Double value) {
            addCriterion("PRICE <", value, "price");
            return (Criteria) this;
        }

        public Criteria andPriceLessThanOrEqualTo(Double value) {
            addCriterion("PRICE <=", value, "price");
            return (Criteria) this;
        }

        public Criteria andPriceIn(List<Double> values) {
            addCriterion("PRICE in", values, "price");
            return (Criteria) this;
        }

        public Criteria andPriceNotIn(List<Double> values) {
            addCriterion("PRICE not in", values, "price");
            return (Criteria) this;
        }

        public Criteria andPriceBetween(Double value1, Double value2) {
            addCriterion("PRICE between", value1, value2, "price");
            return (Criteria) this;
        }

        public Criteria andPriceNotBetween(Double value1, Double value2) {
            addCriterion("PRICE not between", value1, value2, "price");
            return (Criteria) this;
        }

        public Criteria andTypeIsNull() {
            addCriterion("TYPE is null");
            return (Criteria) this;
        }

        public Criteria andTypeIsNotNull() {
            addCriterion("TYPE is not null");
            return (Criteria) this;
        }

        public Criteria andTypeEqualTo(Integer value) {
            addCriterion("TYPE =", value, "type");
            return (Criteria) this;
        }

        public Criteria andTypeNotEqualTo(Integer value) {
            addCriterion("TYPE <>", value, "type");
            return (Criteria) this;
        }

        public Criteria andTypeGreaterThan(Integer value) {
            addCriterion("TYPE >", value, "type");
            return (Criteria) this;
        }

        public Criteria andTypeGreaterThanOrEqualTo(Integer value) {
            addCriterion("TYPE >=", value, "type");
            return (Criteria) this;
        }

        public Criteria andTypeLessThan(Integer value) {
            addCriterion("TYPE <", value, "type");
            return (Criteria) this;
        }

        public Criteria andTypeLessThanOrEqualTo(Integer value) {
            addCriterion("TYPE <=", value, "type");
            return (Criteria) this;
        }

        public Criteria andTypeIn(List<Integer> values) {
            addCriterion("TYPE in", values, "type");
            return (Criteria) this;
        }

        public Criteria andTypeNotIn(List<Integer> values) {
            addCriterion("TYPE not in", values, "type");
            return (Criteria) this;
        }

        public Criteria andTypeBetween(Integer value1, Integer value2) {
            addCriterion("TYPE between", value1, value2, "type");
            return (Criteria) this;
        }

        public Criteria andTypeNotBetween(Integer value1, Integer value2) {
            addCriterion("TYPE not between", value1, value2, "type");
            return (Criteria) this;
        }

        public Criteria andLowPriceIsNull() {
            addCriterion("LOW_PRICE is null");
            return (Criteria) this;
        }

        public Criteria andLowPriceIsNotNull() {
            addCriterion("LOW_PRICE is not null");
            return (Criteria) this;
        }

        public Criteria andLowPriceEqualTo(Double value) {
            addCriterion("LOW_PRICE =", value, "lowPrice");
            return (Criteria) this;
        }

        public Criteria andLowPriceNotEqualTo(Double value) {
            addCriterion("LOW_PRICE <>", value, "lowPrice");
            return (Criteria) this;
        }

        public Criteria andLowPriceGreaterThan(Double value) {
            addCriterion("LOW_PRICE >", value, "lowPrice");
            return (Criteria) this;
        }

        public Criteria andLowPriceGreaterThanOrEqualTo(Double value) {
            addCriterion("LOW_PRICE >=", value, "lowPrice");
            return (Criteria) this;
        }

        public Criteria andLowPriceLessThan(Double value) {
            addCriterion("LOW_PRICE <", value, "lowPrice");
            return (Criteria) this;
        }

        public Criteria andLowPriceLessThanOrEqualTo(Double value) {
            addCriterion("LOW_PRICE <=", value, "lowPrice");
            return (Criteria) this;
        }

        public Criteria andLowPriceIn(List<Double> values) {
            addCriterion("LOW_PRICE in", values, "lowPrice");
            return (Criteria) this;
        }

        public Criteria andLowPriceNotIn(List<Double> values) {
            addCriterion("LOW_PRICE not in", values, "lowPrice");
            return (Criteria) this;
        }

        public Criteria andLowPriceBetween(Double value1, Double value2) {
            addCriterion("LOW_PRICE between", value1, value2, "lowPrice");
            return (Criteria) this;
        }

        public Criteria andLowPriceNotBetween(Double value1, Double value2) {
            addCriterion("LOW_PRICE not between", value1, value2, "lowPrice");
            return (Criteria) this;
        }

        public Criteria andDiscountIsNull() {
            addCriterion("DISCOUNT is null");
            return (Criteria) this;
        }

        public Criteria andDiscountIsNotNull() {
            addCriterion("DISCOUNT is not null");
            return (Criteria) this;
        }

        public Criteria andDiscountEqualTo(Double value) {
            addCriterion("DISCOUNT =", value, "discount");
            return (Criteria) this;
        }

        public Criteria andDiscountNotEqualTo(Double value) {
            addCriterion("DISCOUNT <>", value, "discount");
            return (Criteria) this;
        }

        public Criteria andDiscountGreaterThan(Double value) {
            addCriterion("DISCOUNT >", value, "discount");
            return (Criteria) this;
        }

        public Criteria andDiscountGreaterThanOrEqualTo(Double value) {
            addCriterion("DISCOUNT >=", value, "discount");
            return (Criteria) this;
        }

        public Criteria andDiscountLessThan(Double value) {
            addCriterion("DISCOUNT <", value, "discount");
            return (Criteria) this;
        }

        public Criteria andDiscountLessThanOrEqualTo(Double value) {
            addCriterion("DISCOUNT <=", value, "discount");
            return (Criteria) this;
        }

        public Criteria andDiscountIn(List<Double> values) {
            addCriterion("DISCOUNT in", values, "discount");
            return (Criteria) this;
        }

        public Criteria andDiscountNotIn(List<Double> values) {
            addCriterion("DISCOUNT not in", values, "discount");
            return (Criteria) this;
        }

        public Criteria andDiscountBetween(Double value1, Double value2) {
            addCriterion("DISCOUNT between", value1, value2, "discount");
            return (Criteria) this;
        }

        public Criteria andDiscountNotBetween(Double value1, Double value2) {
            addCriterion("DISCOUNT not between", value1, value2, "discount");
            return (Criteria) this;
        }

        public Criteria andAwardIsNull() {
            addCriterion("AWARD is null");
            return (Criteria) this;
        }

        public Criteria andAwardIsNotNull() {
            addCriterion("AWARD is not null");
            return (Criteria) this;
        }

        public Criteria andAwardEqualTo(Double value) {
            addCriterion("AWARD =", value, "award");
            return (Criteria) this;
        }

        public Criteria andAwardNotEqualTo(Double value) {
            addCriterion("AWARD <>", value, "award");
            return (Criteria) this;
        }

        public Criteria andAwardGreaterThan(Double value) {
            addCriterion("AWARD >", value, "award");
            return (Criteria) this;
        }

        public Criteria andAwardGreaterThanOrEqualTo(Double value) {
            addCriterion("AWARD >=", value, "award");
            return (Criteria) this;
        }

        public Criteria andAwardLessThan(Double value) {
            addCriterion("AWARD <", value, "award");
            return (Criteria) this;
        }

        public Criteria andAwardLessThanOrEqualTo(Double value) {
            addCriterion("AWARD <=", value, "award");
            return (Criteria) this;
        }

        public Criteria andAwardIn(List<Double> values) {
            addCriterion("AWARD in", values, "award");
            return (Criteria) this;
        }

        public Criteria andAwardNotIn(List<Double> values) {
            addCriterion("AWARD not in", values, "award");
            return (Criteria) this;
        }

        public Criteria andAwardBetween(Double value1, Double value2) {
            addCriterion("AWARD between", value1, value2, "award");
            return (Criteria) this;
        }

        public Criteria andAwardNotBetween(Double value1, Double value2) {
            addCriterion("AWARD not between", value1, value2, "award");
            return (Criteria) this;
        }

        public Criteria andCodeIsNull() {
            addCriterion("CODE is null");
            return (Criteria) this;
        }

        public Criteria andCodeIsNotNull() {
            addCriterion("CODE is not null");
            return (Criteria) this;
        }

        public Criteria andCodeEqualTo(String value) {
            addCriterion("CODE =", value, "code");
            return (Criteria) this;
        }

        public Criteria andCodeNotEqualTo(String value) {
            addCriterion("CODE <>", value, "code");
            return (Criteria) this;
        }

        public Criteria andCodeGreaterThan(String value) {
            addCriterion("CODE >", value, "code");
            return (Criteria) this;
        }

        public Criteria andCodeGreaterThanOrEqualTo(String value) {
            addCriterion("CODE >=", value, "code");
            return (Criteria) this;
        }

        public Criteria andCodeLessThan(String value) {
            addCriterion("CODE <", value, "code");
            return (Criteria) this;
        }

        public Criteria andCodeLessThanOrEqualTo(String value) {
            addCriterion("CODE <=", value, "code");
            return (Criteria) this;
        }

        public Criteria andCodeLike(String value) {
            addCriterion("CODE like", value, "code");
            return (Criteria) this;
        }

        public Criteria andCodeNotLike(String value) {
            addCriterion("CODE not like", value, "code");
            return (Criteria) this;
        }

        public Criteria andCodeIn(List<String> values) {
            addCriterion("CODE in", values, "code");
            return (Criteria) this;
        }

        public Criteria andCodeNotIn(List<String> values) {
            addCriterion("CODE not in", values, "code");
            return (Criteria) this;
        }

        public Criteria andCodeBetween(String value1, String value2) {
            addCriterion("CODE between", value1, value2, "code");
            return (Criteria) this;
        }

        public Criteria andCodeNotBetween(String value1, String value2) {
            addCriterion("CODE not between", value1, value2, "code");
            return (Criteria) this;
        }

        public Criteria andUintIsNull() {
            addCriterion("UINT is null");
            return (Criteria) this;
        }

        public Criteria andUintIsNotNull() {
            addCriterion("UINT is not null");
            return (Criteria) this;
        }

        public Criteria andUintEqualTo(Integer value) {
            addCriterion("UINT =", value, "uint");
            return (Criteria) this;
        }

        public Criteria andUintNotEqualTo(Integer value) {
            addCriterion("UINT <>", value, "uint");
            return (Criteria) this;
        }

        public Criteria andUintGreaterThan(Integer value) {
            addCriterion("UINT >", value, "uint");
            return (Criteria) this;
        }

        public Criteria andUintGreaterThanOrEqualTo(Integer value) {
            addCriterion("UINT >=", value, "uint");
            return (Criteria) this;
        }

        public Criteria andUintLessThan(Integer value) {
            addCriterion("UINT <", value, "uint");
            return (Criteria) this;
        }

        public Criteria andUintLessThanOrEqualTo(Integer value) {
            addCriterion("UINT <=", value, "uint");
            return (Criteria) this;
        }

        public Criteria andUintIn(List<Integer> values) {
            addCriterion("UINT in", values, "uint");
            return (Criteria) this;
        }

        public Criteria andUintNotIn(List<Integer> values) {
            addCriterion("UINT not in", values, "uint");
            return (Criteria) this;
        }

        public Criteria andUintBetween(Integer value1, Integer value2) {
            addCriterion("UINT between", value1, value2, "uint");
            return (Criteria) this;
        }

        public Criteria andUintNotBetween(Integer value1, Integer value2) {
            addCriterion("UINT not between", value1, value2, "uint");
            return (Criteria) this;
        }
    }

    /**
     * This class was generated by MyBatis Generator.
     * This class corresponds to the database table SYSCONF_SELL_CATEGORY
     *
     * @mbg.generated do_not_delete_during_merge Wed Jul 12 08:41:20 CST 2017
     */
    public static class Criteria extends GeneratedCriteria {

        protected Criteria() {
            super();
        }
    }

    public static class Criterion {
        private String condition;

        private Object value;

        private Object secondValue;

        private boolean noValue;

        private boolean singleValue;

        private boolean betweenValue;

        private boolean listValue;

        private String typeHandler;

        public String getCondition() {
            return condition;
        }

        public Object getValue() {
            return value;
        }

        public Object getSecondValue() {
            return secondValue;
        }

        public boolean isNoValue() {
            return noValue;
        }

        public boolean isSingleValue() {
            return singleValue;
        }

        public boolean isBetweenValue() {
            return betweenValue;
        }

        public boolean isListValue() {
            return listValue;
        }

        public String getTypeHandler() {
            return typeHandler;
        }

        protected Criterion(String condition) {
            super();
            this.condition = condition;
            this.typeHandler = null;
            this.noValue = true;
        }

        protected Criterion(String condition, Object value, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.typeHandler = typeHandler;
            if (value instanceof List<?>) {
                this.listValue = true;
            } else {
                this.singleValue = true;
            }
        }

        protected Criterion(String condition, Object value) {
            this(condition, value, null);
        }

        protected Criterion(String condition, Object value, Object secondValue, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.secondValue = secondValue;
            this.typeHandler = typeHandler;
            this.betweenValue = true;
        }

        protected Criterion(String condition, Object value, Object secondValue) {
            this(condition, value, secondValue, null);
        }
    }
}